from django.shortcuts import render
from django.views import View
from django_redis import get_redis_connection
from django import http
import random,logging

from verifications.libs.captcha.captcha import captcha
from . import constants
from meiduo_mall.utils.response_code import RETCODE
from verifications.libs.yuntongxun.ccp_sms import CCP
from celery_tasks.sms.tasks import send_sms_code


# Create your views here.


# 创建日志输出器
logger = logging.getLogger('django')


class SMSCodeView(View):
    """短信验证码"""

    def get(self,request,mobile):
        """
        :param mobile: 手机号
        :return: JSON
        """

        # 接收参数
        image_code_client = request.GET.get('image_code')
        uuid = request.GET.get('uuid')
        # 校验参数
        if not all([image_code_client,uuid]):
            return http.HttpResponseForbidden('缺少必传参数')

        # 创建连接到redis的对象（保存图新验证码）
        redis_conn = get_redis_connection('verify_code')

        # 判断用户是否频繁发送短信验证码----------------------
        # 提取发送短信验证码的标记
        send_flag = redis_conn.get('send_flag_%s' % mobile)
        if send_flag:
            return http.JsonResponse({'code':RETCODE.THROTTLINGERR,'errmsg':'发送短信过于频繁'})

        # 提取图形验证码
        image_code_server = redis_conn.get('img_%s' % uuid)
        if image_code_server is None:
            return http.JsonResponse({'code':RETCODE.IMAGECODEERR,'errmsg':'图形验证码已失效'})
        # 删除图新验证码
        redis_conn.delete('img_%s' % uuid)

        # 将bytes转字符串，在比较
        image_code_server = image_code_server.decode()
        # 对比图形验证码(.lower()转小写，再比较）
        if image_code_client.lower() != image_code_server.lower():
            return http.JsonResponse({'code':RETCODE.IMAGECODEERR,'errmsg':'输入图形验证码有误'})
        # 生成短信验证码: 随机6位数字,补位到6位数字
        sms_code = '%06d' % random.randint(0,999999)
        #手动输入日志，记录短信验证码
        logger.info(sms_code)

        # 创建redis管道-----------------
        pl = redis_conn.pipeline()
        # 将命令添加到队列中--------------
        # 保存短信验证码
        pl.setex('sms_%s' % mobile, constants.SMS_CODE_REDIS_EXPIRES, sms_code)
        # 保存发送短信验证码的标记
        pl.setex('send_flag_%s' % mobile, constants.SEND_SMS_CODE_INTERVAL, 1)
        # 执行-------------
        pl.execute()

        # 发送短信验证码
        # CCP().send_template_sms(mobile, [sms_code,constants.SMS_CODE_REDIS_EXPIRES // 60], constants.SEND_SMS_TEMPLATE_ID)
        # 要使用Celery发送短信验证码
        # send_sms_code(mobile, sms_code) #错误写法
        send_sms_code.delay(mobile, sms_code) # 要调用.delay()


        # 响应结果
        return http.JsonResponse({'code':RETCODE.OK,'errmsg':'发送短信成功'})


class ImageCodeView(View):
    """图形验证码"""

    def get(self,request,uuid):
        """

        :param uuid: 通用唯一识别码，用于唯一标识该图形验证码属于哪个用户
        :return: image/jpg
        """
        # 接收和校验参数 已通过子应用url以get方式获取并通过正则校验
        # 实现主体业务逻辑： 生成，保存，响应图形验证码
        # 生成图形验证码
        text,image = captcha.generate_captcha()
        # 保存图形验证码
        redis_conn = get_redis_connection('verify_code')
        # redis_conn.setex('key','expires','value')
        redis_conn.setex('img_%s' % uuid, constants.IMAGE_CODE_REDIS_EXPIRES, text)
        # 响应图形验证码
        # return http.HttpResponse('响应体','数据类型')
        return http.HttpResponse(image, content_type='image/jpg')